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WARRANTEE INFORMATION 


The SSB EDITOR is provided AS IS without warrantee. Reasonable care 
has been taken to insure that the software operates as described in 
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INTRODUCTION 


The SSB Text Editor for DOS68 is a powerful line and content oriented 
editor which is simple to use, and easy to learn. The editor accepts 
both upper and lower case ASCII characters for text data as well as 
its command set, making it useful for generating text files. The 
flexibility of the editor lends its use in applications ranging from 
text preparation in business environments to commercial software 
development. The editor has the capability of operating upon files as 
large as the capacity of a disk. 


Reading through the manual, you will soon discover the power of the 
editor. *Many of the time saving, advanced features may seem a little 
confusixy at first. The best way to learn the editor's features is to 
read-<hrough the editing commands, and study the "Mini-Tutorial. Try 
rvining the editor using the examples to learn the basics, then study 
“the advanced commands to grasp the full power and capabilities of this 
editor. 


To aquaint the user with the file management conventions used by the 
editor, the name of the file to be edited, unless otherwise specified, 
defaults to a filename bearing a type 1 extension. Similarly, default 
backup file names as well as editor temporaries are assigned type 5 
and 8 extensions, respectively. DOS68 initially defines a type 1 
extension as .TXT, a type 5 extension as .BAK, and a type 8 extension 
as .TMP. These extension types and their literal equivalents will be 
used interchangeably throughout the remainder of this manual. This 
manual reflects information that is compatible with versions 5.9, 
5.0A, and 5.0C of the editor. 
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INVOKING THE EDITOR 


The editor is invoked using the EDIT command, which uses the general 
form of: 


EDIT,<INPUT FILE SPEC>, [<OUTPUT FILE SPEC>] 


The name of the file(s) specified as input or output default to names 
bearing a type 1 extension. The default filename extension can _ be 
overridden by simply defining the extension explicitly. For example, 
if FILE.A is specified as part of an input or output filespec, then 
FILE.A will be operated upon rather than FILE.TXT, which bears the 
type 1 extension. Type 5 extensions are reserved for the default 
backup file generated by the editor, and the type 8 extension is 
reserved for editor temporaries used by the editor at run-time. 
Therefore the use of type 5 and 8 extensions within input or output 
filespecs is restricted. The drive on which the file(s) will be found 
defaults to the work drive as asSigned at editor run-time. Refer to 
the SET command documentataion regarding work drive and extension type 
assignments. 


CREATING A FILE 


Creating a new file with the editor is accomplished using a variation 
of the general command form by ommitting the input file spec. For 
example: 


EDIT, ,NUFILE 


will initiate the creation of the file NUFILE.TXT on 
the current work drive. The editor will display: 


NEW FILE: 
1,00= 


indicating its readiness to accept text input from the user, Again, 
if no filename extension is specified, the editor will by default 
assign a type 1 extension to the filename. 
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UPDATING AN EXISTING FILE 


The simplest and most convenient command form for invoking the editor 
to update an existing file is: 


EDIT, TEST 


Since a specific drive is not specified, the drive is assumed to. be 
the DOS68 work drive as defined by the user. The editor will load the 
File TEST.TXT found on the work drive into the text buffer. After the 
editing process..is completed, control is returned to DOS68. During 
the DOS68 retyzn process, the editor is transparently performing 
housekeepiryg on the work drive. In this example, if the file TEST.BAK 
exists, it is deleted, Next, the input file TEST.TXT containing the 
origtyer data is renamed TEST.BAK. Finally, a temporary file named 
TEST.4“MP reflecting all the changes made while in the editor is 
renaxed TEST.TXT. The automatic maintainence of the new copy and old 
cepy simplifies disk management for the user. Note that if additional 


-Old versions of TEST.TXT are required, simply rename 


4 


TEST.BAK before each edit pass. 


If you desire to edit ae file, but want to give the output file a 
another name, use the command form: 


EDIT, TEST, TEST2 


The file TEST.TXT found on the work drive will be loaded into the text 
buffer, and the new file TEST2.TXT will be created on the same drive. 
This same general form is used to edit an input file found on _ one 
drive, and create an output file on anotherdrive. For example: 


EDIT,@:TEST2,1:TEST2.NEW 


would allow an edit of TEST2.TXT on drive @, with the output file 
TEST2,NEW existing on drive 1] at the conclusion of the edit session, 
Note that the .NEW extension will override the default type 1 
extension. 


If at some point it is necessary to edit a file bearing reserved 
extensions such as a types 5 or 8, a qualified output file must _ be 
specified. Therefore, if the file TEST.BAK must be edited, a command 
like: 


EDIT,TEST.BAK, TEST.OLD 


should be used. If, however, the user does not specify a qualified 
output filespec, then the editor display the message: 


"YOUR INPUT FILE EXTENSION WITHOUT AN 
OUTPUT FILE SPECIFIED, IS NOT ALLOWED" 


The editor will transfer control back to DOS68 as type 5 and 8 
extensions are reserved for the editor, 
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DEFERRED FILE INPUT 


To invoke the editor using its deferred 
command without file specs as shown below: 


EDIT 
The editor, once loaded 
specs. with: 

FILENAME: 


The editor is now ready to accept file 
capability of entering file specifications after 
loaded and started can be advantageous to. single 
multi-drive disk system users. The user can for 
disk on which the editor resides, and mount a disk 
may yet contain the file(s) which will be operated 


input mode, 


specifications. 


use the EDIT 


and running, will prompt the user for file 


Having the 
the editor has been 


Grive as well as 
example, remove the 
which contains or 


upon by the editor. 


The user has virtually "gained" an additional drive on his system! 
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EDITOR DIRECTIVES 
DIRECTIVE OVERVIEW 


There are four groups of editor directives: environment directives, 
system directives, "current line" movers, and edit directives, A 
complete description of all directives in each group is covered in 
this section, In the following descriptions, quantities enclosed in 
Square brackets ([ .«.«.]) are optional, and may be omitted. Vertical 
lines (|) are used to separate the options, 


STRING ARGUMENTS 


Several of the editor directives use character strings aS arguments, 
These arguments are either matched against strings in the text, or 
replace a string in the text. A string argument begins after a 
delimiter character and continues as a sequence of any legal 
characters until the delimiter is again encountered, The delimiters 
are not considered part of the string to be used in the matching or 
replacement operations. Although the delimiters in the following 
descriptions are frequently represented as slashes, "/", any legal 
non-blank, non-alphanumeric character may be used as the delimiter 
such as * / ( ) $ = ,. [{] : ' etc. Note that the following 
characters may not be used to enclose strings unless they are preceded 
by either a plus (+) or minus (-) sign: "“" (denotes first line of 
the buffer),"!" ( denotes the last line of the buffer), "-" (denotes 
target is above current line), and the character denoted by LINO 
(Normally a pound sign) which is used to flag line numbers. The 
delimiter character is redefined in each new request by its appearance 
before a string. I1f two strings exist in one directive (as in the 
Change directive), the same delimiter character must be used for each 
string. 


All of the editor directives use the <line> information preceeding the 
directive to position the pointer prior to any directive action. The 
<line> parameter may of course be null, meaning leave the pointer at 
its current position. All of the following are _ valid <line> 
designators: Pee Sy oe ra 


1, Any number References a specific line number. 
2. +n i: Denoting the nth subsequent line. 

3. -n Denoting the nth previous line. 

4. /<string>/ Referring to the next line in the 


file containing the indicated 
string of characters, 


5. —-/<string>/ References a previous line containing 
the indicated string... 


6. —- denotes the first line of the file. 
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7. ! denotes the last line of the file. 
8. null stay at current line, 


Many of the editor directives require <target> information. This 
tells the editor to operate on the "current" line and all other lines 
in the file up to the line referenced by the <target>. In cases where 
a <target> is required, leaving it null will make the <target> default 
to 1, meaning only the current line will be affected by the directive. 
All of the following are valid <target> designators: 


1. an integer n indicates that n lines should be 
affected by the edit operation. 


2. #n denotes the line number of the 
last line to be affected, 


3. /<string>/ Genotes the next line in the file 
containing the specified character 
string. 

4. -/<string>/ references a previous line containing 


the indicated string. 


58 denotes all lines up to the top of 
the file, 
6. ! references all lines down to the 


bottom or last line of the file, 


7. +n indicates that n lines should be 
| affected and in which direction 
from the current line. 


8. (null) Gefaults to 1 and only the current 
line is affected. 


As we have seen, the form <target> is used to specify a range of lines 
to which the directive will apply. The directive will be applied to 
each line, starting with the line specified by <line> and continuing 
until the target is reached. 


If a string <target> is specified, the directive will apply to 
successive lines of text until a line containing the string is 
reached. Processing proceeds downward in the file unless the target 
is preceded by a "-" (minus sign), indicating that processing is to 
occur upward (toward the first line) in the file. Targets may also be 
preceded by a plus sign (indicating downward movement). If a line 
number target is specified, processing begins at <line> and proceeds 
toward the target line number. Some examples of <target>s are: 


2 

+19 

ae. 
/STRING/ 
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+/STRING TARGET/ 

-/BACKWARD DISPLACEMENT TO A STRING/ 
+*ANY DELIMITER WILL WORK FOR STRING* 
++EVEN PLUS SIGNS WILL WORK+ 
#23.000 


COLUMN SPECIFICATION 


Any "/<string>/" descriptor may be postfixed with a column number 
immediately after the delimiter which indicates that the preceding 
string must begin in the column specified to be found, 


If the column specified is not in the rrange of the ZONE in effect, 
the request will be ignored. Some examples are: 


/IDENT/11 
/PROGRAM/77 
*LABEL*2 
« COMMENT. 38 


REPEATING COMMANDS 


The last editor directive can be repeated while in the command mode by 
typing a control "D", This simplifies repetitive operations by 
eliminating the need to continually re-enter the directive. The 
INSERT and OVERLAY directives should not be repeated. Some directives 
which are useful to repeat are 


P23 To print a screen full of lines 
at a time. ee: 


NEW To step through the input file 
with the touch of a key. 

F/LABEL/ To step through the text buffer 
on each occurrence of the string 
"LABEL" 


MULTIPLE COMMANDS 


The editor supports a user definable EOL or End Of Line character to 
allow multiple commands to exist on a single command line. Using the 
muliple command capability of the editor, the user can compose. and 
execute unique, complex editing functions which would otherwise 
require a series of individual commands entered separately. The EOL 
character can be defined as well as changed by the user with the 
editor's SET directive. The INSERT and OVERLAY directives can be used 
as part of multiple commands, but they cannot be followed by another 
command. With the EOL set to "$", the following example shows’ the 
implementation of a multiple command: 


TSF/END/SC/END/STOP/$-18P20S$T 
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This multiple command moves the line pointer to the top of the buffer, 
finds the first occurrence of the string "END", changes "END" to 
"STOP", backs the line pointer back 1@ lines and prints the next 26 
lines, then restores the pointer to the top of the buffer 


TABS 


The editor supports tabbing with up to 28 tab stops. The TAB 
character and the tab FILL character are definable by the user with 
the editor's SET directive. In using tabs, the tab character is 
imbedded in the line where it will be expanded when the end of the 
line is recieved. If the tab stops or the tab character have not been 
defined, yet some tab character has been propagated thoughout the 
file, the tabs can be expanded by first defining the tab character’ to 
be the same as what exists in the file, and then invoking the EXPAND 
directive. Note that if the tab character has been set, subsequent use 
of the INSERT or REPLACE directives will cause automatic tab 
expansion, If the tab character is added to the file using the APPEND, 
CHANGE or OVERLAY directives, it will remain in the file until an 
EXPAND directive expands the lines containing the tab character. 
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ENVIRONMENT DIRECTIVES 
H[EADER] <columns> 
MEANING: 


A line of <columns> headings will be displayed. The heading is 
of the form "123456789812..." to indicate the column number. 
Columns for which tab stops are set will contain a minus 
character instead of the normal digit. If a column count is 
given, it becomes the default count such that if just "H" is 
typed afterwards, that number of columns will be printed. 


EXAMPLES: 
HEADER 72 Display column number headings for 
72 columns, 
H 30 Display column numbers for 39 


columns, 


NU[MBERS] [OFF]ON] 
MEANING: 


The line number flag is turned off or on. If the flag is off, 
then line numbers will never be printed. If neither "OFF" nor 
"ON" is specified, then the flag will be toggled from its 
current state. 


- EXAMPLES: 
NUMBERS OFF ; Turn line number printing off. 
NU ON Turn it back on, 
NU Toggle from "ON" to "OFF" or from 


"OFF" to “ON". 


REN [UMBER] 
MEANING: 


The RENUMBER directive will renumber all of the lines in the 
current edit file, Lines in the renumbered file will start 
with line number "1.980" and will have an increment of "1.606". 
The line which was "current" before the command will still be 
the current line after the command (although its number will 
probably have been changed). 


EXAMPLES : 


Renumber the lines in the current 
working file. 
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REN Renumber the lines in the current 
working file. 
SET <name> = ‘'<char>' 
MEANING: 


SET is used to define certain special characters or _ symbols. 
The <name>s which may be set are: 


TAB - the tab character, 


FILL the tab fill character, 


EOL = the end of line character which may be used 
to separate several commands on a single line, 


LINO 


The line number flag character which is used 
to indicate that a target is a specific line 
number. 


Setting the TAB character and the FILL character the same will 
defeat the TAB feature, therefore there is no logical reason to 
Go this. 


Setting the EOL character will allow the user to use _ multiple 
commands in a single command line. INSERT and OVERLAY cannot 
be followed by other commands. An example of EOL use (with EOL 
set to "$") is: y 

D2SP19ST 


This sequence will delete the first 2 lines of the buffer, then 
print the next 1@ lines, and finally return the pointer to’ the 
top of the buffer. 


The default values are: TAB and EOL are "null". 


FILL is "space" 


LINO is “" 
EXAMPLES: 

SET TAB = ':! Set the tab character to semicolon. 

SET TAB = '! Disable tabbing by setting the tab 
character to null. 

SET FILL = ' ' Set the tab fill character to a 
blank. 

SET EOL = '$! Set the EOL character to $. 
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SET LINO = '@! Set the line number target escape. 
TAB [<COLUMNS>] /o, iH ej 25° 
MEANING: 


Used to set the tab stops. All previous tab stops are cleared. 
If no columns are specified then the only action is to clear 
all tab settings. Any TAB characters occurring beyond the last 


tab stop are left in the text. The maximum number of TAB stops 
allowed is 290. 


EXAMPLES : 
TAB 11, 18, 38 Set tab stops are columns ll, 18 
and 30. 
TAB 7 72 Set tab stops for a FORTRAN program, 
TAB Clear all £ab stops. 


V[ERIFY] [OFF|ON] 


MEANING: 


The verify flag is turned "ON" or "OFF". The verify flag is 
used by the directives CHANGE, and NEXT (and several others) to 
display their results. If neither "ON" nor "OFF" is specified, 
then the flag will be toggled from its current state, 


EXAMPLES: 
VERIFY OFF Turn verification off. 
V ON Turn it back on, 
MEANING: 


"Xx" is the cursor control command. Any time this command is 
entered, the editor will issue the 6 special character string 
previously set up. See "MODIFYING THE EDITOR" for details on 
how to define the string 


EXAMPLES : 


X Output cursor control string. 
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Z{ONE] [Cl], [C2] 
MEANING: 


ZONE is used to restrict all sub-string searches (FIND, CHANGE, 
<target>s, etc.) to columns Cl to C2 inclusive. Any substrings 
beginning outside those columns will not be detected, If Cl 
and C2 are not specified, then the zones will be reset to their 
defaults (columns 1 and 136). 


EXAMPLES: 
ZONE 11, 29 Restrict searches to columns 1l 
through 29. 
ZONE Search columns 1 through 136. 
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SYSTEM DIRECTIVES 


CLOSE 
MEANING: 
CLOSE performs the same text buffer and file transfers as LOG 
without returning to DOS68. The editor will remain running to 
allow continuous file editing. The editor will prompt the user 
for file specifications with the message: 
FILES: 
EXAMPLE: 
CLOSE 
FILES: LETTER.OLD,1: LETTER.NEW 
DOS 
MEANING: 
The DOS command causes the editor to terminate execution and 
return control to DOS68. The input file is left un-changed, 
the temporary work file is deleted, and no output file is 
generated. 
EXAMPLE: 
DOS 
LOG 
MEANING: 
Conclude an edit session and exit the editor by writing the 
contents of the text buffer to the output file, and transfer 
the remainder of the input file to the output file. Control is 
transfered to DOS68, If the input file is large, the message 
"BUFFER FULL - COMPLETE FILE NOT READ" will appear, indicating 
that the editor is utilizing the entire text buffer in the 
process of transferring the contents of the input file to the 
output file. 
EXAMPLE: 


LOG 
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NEW 


READ 


MEANING: 


The NEW command transfers the contents of the text buffer from 
the top down to but not including, the “current" line into’ the 
output file. Next, as much unread data that can be placed into 
the text buffer will be read from the input file. Note that if 
the input file is large, the message "BUFFER FULL - COMPLETE 
FILE NOT READ" may appear. This is an indication that there is 
still unread data in the input file although the text buffer 
was filled to usable capacity. Sufficient free space remains 
in the buffer for additional text storage by the user, 


The NEW command may be used in event that the "NOT ENOUGH ROOM" 
message appears while editing a new or existing file. To 
remedy the situation, issue a NEW command, and the contents of 
the text buffer from the top line to the current line will be 
transferred to the output file, with the current line now the 
top line in the buffer. 


NEW may also be used anytime during the edit session, but keep 
in mind that once it has been used, all parts of the file which 
were above the current line pointer will become’ inaccessable 
for the remainder of the session, The editor can only operate 
on text in the text buffer, therefore, global commands such as 
CHANGE and FIND will be global only with respect to the text 
currently in the buffer, and not the entire file, unless of 
course, the entire file will fit in the buffer. 


EXAMPLE: 


NEW 


MEANING: 


The READ command gives the user the capability of 
transferring the contents of a specified disk file into 

to the end of the current text buffer, and the last line 
read will become the new current line. The number of 

lines that will be read are limited only by the amount of 
free space currently in the text buffer. Upon receipt of a 
READ command, the editor will respond with: 


FILE NAME: 


after which the name of the file to be read is 

entered. Note that if the entire contents of the specified 
file does not fit within the free space, the "BUFFER FULL - 
COMPLETE FILE NOT READ" message will appear. 
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EXAMPLE: 
READ 


FILE NAME:1:MODULE.TXT 


RETRY 
MEANING: 
In event of a fatal disk error during a NEW, LOG, or STOP 
operation, RETRY will create a new output file and attempt 
to continue the disk I/O operation where it left off. For 
example, if a disk error 7 occurs, (disk full error), then 
the message: 
CORRECT PROBLEM AND TYPE "RETRY" 
TO ABORT AND RETURN TO DOS - TYPE "DOS" 
will appear. Typing RETRY will cause the output file to _ be 
re-created, and the disk I/O operation to be continued. Note 
that if DOS is typed, the editor will abort leaving the file 
that was being edited unchanged, 
STOP 
MEANING: 
Same as LOG. | 
EXAMPLES : | 


STOP 


WRITE [<target>] 


MEANING : 


Write all lines from the current line through the target line 
to a specified disk file. Upon receipt of WRITE, the editor 


will prompt the user for the file specification of the file 
with: 


FILE NAME: 
EXAMPLE 3: 
WRITE *TARGET STRING* Write all lines from the current line 


to the line containing "TARGET STRING" 
FILE NAME: 1:MYFILE.TXT into the file MYFILE.TXT on drive l. 
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CURRENT LINE CONTROL 


B[OTTOM] 


MEANING: 


Move to the last line in the file and make it the current line, 


EXAMPLES: 
BOTTOM Make the last line of the file the 
current line, 
B 


F[IND] <target> [<occurrence>] 


MEANING: 


Move the current line pointer to the line specified by <target> 
and make it the current line. If the VERIFY flag (see VERIFY) 
is on, the line will be printed. If <occurrence> is specified 
(an unsigned integer or an asterisk), the directive will be 
repeated <occurrence> times. An asterisk means all occurrence 
of the <target> will be found until the bottom or the top of 
the file is reached. If the target is not reached, the current 
line pointer will not be moved. 


EXAMPLES: 

FIND /STRING/ Find the next line containing the 
string "STRING", 

F /THREE LINES/ 3 Find the next three lines contain- 
ing the string "THREE LINES", 

F/PUSH/ * Find all following occurrences of 
the word PUSH, 

F-/PROGRAM/7 * _ Find all previous lines which 
contain the characters "PROGRAM" 
beginning in column seven. 

N[EXT] <target> [<occurrence>] 


MEANING: 


The line specified by the target is made the current line. If 
the VERIFY flag is on, the line will be printed. If 
<occurrence> is specified, it must be an unsigned integer, It 
indicates which next occurrence of a line containing the target 
is to be made the current line. If the target is not reached, 
the current line pointer will be positioned at the bottom of 
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the file (top of the file for a negative <target>). If no 
target is specified, the next line will be made the current 


line, 
EXAMPLES: 

NEXT 5 . Make the fifth following line the 
current line, 

N Make the next line the current line. 

N-10 Make the tenth previous line current, 

N/STRING TARGET/ Make the next line containing 
"STRING TARGET" to be the current 
line. 


N/THIRD OCCURRENCE/ 3 Make the third line containing the 
indicated string the current line. 


T[OP] 
MEANING: 


The first line of the file becomes the current line, 
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A[PPEND] /<string>/ [<target>] 
MEANING: 


Append the specified <strings> just beyond the last character 
of the ‘current line (and to successive until the target is 
reached). If the string is postfixed with a column number, 
then append the string beginning at the specified column 
‘(rather than at the end of the line). Any characters 
previously in the line following the specified column will be. 


lost. 
EXAMPLES : 
APPEND /./ Append a period to the end of the 
current line, 
A *HELLO* 2 Append the word "HELLO" to the end 


of the current line and to the end 
of the next line, 


A/SEQUENCE/73 *END*7 Append the word "SEQUENCE" starting 
in column 73 of the current line and 
successive lines until a line con- 
taining the characters "END" begin- 
ning in column seven is found, 


C[HANGE] /<string> /<string> / [<target> [<occurrence>] ] 


MEANING: 


Replace the string specified by <string> with the string 
specified by <string> . If no <target> is specified, only the 
current line is affected. The slashes represent any nonblank 
Gelimiter character. <occurrence> is used to specify which 
occurrence of <string> is to be replaced in each line. It is 
either an unsigned integer or an asterisk, "*" signifying that 
all occurrence of the substring <string> are to be replaced 
with <string> . By default, only the first occurrence will be 
changed. Note that if <occurrence> is specified, and if 
changes are to occur to the current line only, then the target 
should be al (one). 


EXAMPLES: 
CHANGE /THIS/THAT/ Replace the first occurrence of 
"THIS" in the current line with 
"THAT", ; 
C /FIRST/LAST/16 Change the first occurrence of 


"FIRST" to "LAST" in the current 
line and also in the nine follow- 
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ing lines. 


C /NEW/OLD/ /A TARGET/ Change the first occurrence of 
"NEW" to "OLD" in each line down 
through the line containing the 
String "A TARGET", 


C ,A,, ~10 * Remove all "A"s in the current 
line and in the nine preceding 
lines. 

C*HELLO* Delete the character string 


"HELLO" from the current line. 


CO[PY] <destination-target> [<range-target>] 
MEANING: 


The current line and successive lines until the <range- target> 
is reached are copied so that they follow the line specified by 
destination-target. The default destination-target is 1, 
thereby causing a copy of the current line to be placed after 
the next line. After the directive is executed, the current 
line pointer will be positioned at the new position of the last 
line copied. Some lines may be renumbered after a copy. 


EXAMPLES: 
co 18 Put a copy of the current line 
after line 18. 
COPY #3 4 Copy four lines beginning with the 
current line and place them after 
line 3% 


CO /HELLO COLLY/ +/END OF RANGE/ 
After the next line which 
contains the string "HELLO DOLLY" 
place a copy of each line starting 
with the current line through the 
line containing "END OF RANGE" 
D[ELETE] [<target>] 
MEANING: 
The current line (and successive lines until the target is 
reached) is deleted. After the directive is executed, the 
current line will be the line following the last line deleted, 


EXAMPLES: 


DELETE 5 Delete five lines (the current 
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line and the next four lines), 
D Delete the current line, 


D /STRING/ Delete lines from the current 
line through the next line that 
contains the string "STRING". 


EXP[AND] [<target>] 
MEANING: 


The current tab character is expanded within all lines, 
beginning with the current line (and down to and including the 
line specified by target). Since tabs are normally expanded as 
lines are inserted into the file, this directive is primarily 
of use when one has forgotten to define a tab character, 


EXAMPLES : 
EXPAND 109 Expand 1@@ lines starting with 
the current line. 
EXP Expand the current line. 
I [NSERT] 
MEANING: 


The editor will enter the buffered input mode, prompting with 
line numbers (unless line numbers have been disabled, see _ the 
"NUMBERS" directive) and insert the lines below the current 
line. Buffered input continues until a line, beginning with the 
breakpoint character (pound sign) in column one is received. 
The characters following the breakpoint character are treated 
as an editor directive. The editor will try to choose an 
insertion increment sufficient to insert at least 18 lines or, 
if that is not possible, the smallest increment possible. The 
current line pointer is positioned at the last line inserted, 
It should be noted that the editor may renumber text lines 
following the inserted text if the inserted line numbers 
overlap line numbers’ previously in the file. If renumbering 
occurs, then the message "SOME LINES RENUMBERED" will appear, 
indicating that renumbering took place, 


EXAMPLES: 
INSERT Accept line input after the current 
line, 
I 
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L[NSERT] <text> 


MEANING: 
The text (sequence of characters) which immediately follows the 
separator (or blank) after the directive name will be inserted 
as a separate line below the current line of tthe file. The 


line inserted becomes the current line. It should be noted 
that the editor may renumber text lines following the inserted 
text if the inserted line numbers overlap line numbers 
oreviously in the file. 
EXAMPLES: 
I THIS BELOW THE CURRENT LINE OF THE FILE 


INSERT EVERYTHING AFTER THE FIRST BLANK, 


L[Ist] [<target>] 
MEANING: 


LIST lines on the system printer through DOS68. Beginning with 
the current line, lines are printed on the system printer until 
the line specified by target is reached. By default, only tie 
current line will be listed, 


EXAMPLES: 
L List the current line. 
LIST 5 List five lines starting with the 
current line. 
L -1@ List the current line and the 
nine previous lines. 
LIST *STRING* ~~ Gist all lines down through the 
-- next line containing "STRING". 
L -/SLRING/ List all lines up through the 
next previous line containing 
"STRING". 


MO [VE] [<destination-target> {<range-target>] } 


The current line (and successive lines until the <range- 
target> is reached) is moved so that it follows the line 
specified by <destination-target>. The default <destination- 
target> is 1, thereby moving the current line after the next 
line in the file. The default <range-target> is 1, thereby 
moving only one line, After the directive is executed the 
current line pointer will be positioned at the new position of 
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the last line moved. 
MOVE. 
EXAMPLES : 


MOVE 3 


MO 1 /TARGET STRING/ 


MO -/PROGRAM/ 5 


MO 18 -5 


O[VERLAY} {[<delimiter>] 


MEANING: 


Some lines may be renumbered after a 


Move the current line down three 
lines, 


Insert the current line and all 
lines down through the line con- 
taining “TARGET STRING" after 
line i I 


Move five lines (including the 
current line) up within the 

file so that they follow a line 
containing the character "PROGRAM"/ 


Move the current line and the 
four previous lines below line 19. 


The current line is printed, then a line of input is accepted 
from the terminal (the overlay line). The overlay line will be 
positioned directly beneath the line printed out, Each 
character of the overlay that is different from the <delimiter> 
character (default is a blank) will replace the corresponding 
character in the current line. The overlaid line will be 
printed if verify is "ON". 


EXAMPLES: 
OVERLAY 


25.098 


OVERLAY Ss 


25.990 


O[VERLAY] <d><text> 


MEANING: 


U 


THIP IS THE CORRENT LUNE. 


ee 


THIS IS THE CURRENT LINE, 


This directive is similar to, the previous forms of the OVERLAY 
directive with these differences:: (1) The current line is not 
printed, (2) The remainder,of the directive 


EXAMPLES : 


OVERLAY-~---AT-------- (CURRENT) ----- 
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25.0@ = THAT IS THE (CURRENT) LINE 


P[RINT] [<target>] 
MEANING: 
Beginning with the current line, lines are printed until the 


line specified by target is reached. By default, only the 
current line will be printed. 


EXAMPLES: 
Pp Print the current line, 
PRINT 5 Print five lines starting with the 
current line. 
P -16 Print the current line and the 
nine previous lines, 
PRINT *STRING* Print all lines down through the 
next line containing "STRING", 
P -/STRING/ Print all lines up through the 
next previous line containing 
"STRING", 


R[EPLACE] [<target>] 


MEANING: 
A DELETE from the current line through the <target> line is 
performed. The editor then enters the buffered input mode, 
putting the new lines into the area vacated, It is not 


necessary to enter the same number of lines as were deleted, 
The line numbers of the lines inserted will probably not be the 
same as those deleted, The current line pointer will be 
positioned at the last line inserted. By default, only the 
current line will be deleted. 


EXAMPLES: 
R | - Replace the current line, 
REPLACE 16 Replace ten lines starting with 
the current line. | 
R /TARGET STRING/ Replace all lines from the current 


line through the line containing 
"TARGET STRING". 
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=<text> 


MEANING: 


The "=" directive replaces the current line with the text 
supplied. The replacement text begins with the first character 
following the 


equals’ sign. The current line pointer is not 
moved. 


EXAMPLES 


THIS IS THE REPLACEMENT TEXT. 


(null) 


MEANING: 


The null directive (i.e., just a carriage return) prints the 
current line, 
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SYSTEM CHARACTERISTICS 


MAXIMUM LINE NUMBER - The maximum line number is 9999.99, If more 
than 9,999 lines are entered, the line number counter will turn over 
(go back to 8), therefore, the editor should not be used with files of 
16,0808 lines or longer. (this is not really a limitation since 186,66¥ 
null lines followed by a carriage return uses up to 40K of memory! 


INPUT BUFFER SIZE - The input buffer will hold 136 characters, 12 
more than 136 characters are typed, they will be ignored and a "bell" 
character will be output to the terminal. To terminate the line, it 


is necessary to type the backspace character and then a carriage 
return. 


EDITOR SYSTEM INPUT/OUTPUT ~ All editor I/O, whether disk, terminal, 
Or printer, is processed with the drivers used by DOS68. This is to 
point out that the terminal control parameters defined by the user 
through SET.$ are in effect during the operation of the editor, 
Please refer to the DOS68 documentation regarding the terminal ccutrol 
parameters and the definition of them with SET.$ 
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MODIFYING THE EDITOR 


A partial source listing is included with this manual to aid those who 
would wish to modify the editor. Most modifications will not _ be 
required by most users, therefore only a few parameters will be 
elaborated upon here. Users who wish to modify the editor beyond the 
scope of the parameters mentioned here are urged to order a complete 
source listing of the editor. 


To make changes in the editor, type GET,EDIT.$ followed by a carriage 
return, This will load the editor and return control back to _ DOS. 
After making the changes, use the SAVE command to save the editor back 
on the disk as a command file. Save from $8108 to S$1D00, with a 
transfer address of $8100. 


MEMORY END - The amount of memory used by the editor for its’ text 
buffer is determined primarily by the DOS68 MEMAX parameter, If for 
some reason MEMAX is undefined ($8988) then the editor parameter 
MEMTOP will be used, It is extremely important to note that both 
MEMAX and MEMTOP Must not be lower than $2000, otherwise 
unpredictable results may occur, Refer to the DOS68 documentation 
regarding MEMAX and how to set this system parameter. 


CURSOR CONTROL STRING - The cursor control string printed upon the 
receipt of the X command is located at location CNRSTR. It is 
currently set to 6 nulls, but may redefined by the user as required. 
The string must be terminated by $94. 
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9108 


0180 
9183 
8106 


0198 
918B 
Q1BE 
01186 
@113 
0116 


@119 


7E 
7E 
5E 


BD 
7D 
26 
TE 
TE 
7E 


00 


163A 
8419 
0) 


72C4 
0048 
G3 

72Cl 
7312 
730F 


0995 
0896 
8897 
0298 
8899 
9100 
81081 
9192 
9183 
0104 
81085 
8196 
@187 
9198 
9109 
6119 
@111 
6112 
6113 
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PARTIAL SOURCE LISTING 


ORG $160 
* PROGRAM STARTS HERE 


START JMP DEDIT 
RESTRT JMP PEDIT 
MEMTOP FDB MEMLIM MEMORY LIMIT 


* EXTERNAL I/O ROUTINES ’ 


INCH JSR ZGETCH CRT INPUT 
OUTCH TST PRTFLG HARD-COPY ON? 
BNE POUCH 
JMP ZPUTCH CRT OUTPUT 
POUCH JMP ZHCOUT PRINTER OUTPUT 
PINIT JMP ZHCINT PRINTER INIT 
* USER DEFINABLE 'X' COMMAND CHARACTER STRING 
CNRSTR FCB 0,0,9,8,0,0,4 
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MINI-TUTORIAL 


The purpose of this section is to briefly introduce the reader to the 
use of the SSB Text Editing System. We will, therefore, illustrate 
its use with a number of examples. In order to make it more obvious 
what things are typed by the user and what things are displayed by the 
editor, we will subscribe to the convention that things underlined are 
user-typed and things not underlined are displayed by the editor. 


When the editor is initially entered, the response is as shown above. 
At this time we will create our file by simply typing all lines. until 
finished, terminating each line with a "carriage return", 


NEW FILE: 

1.00 =THIS IS AN EXAMPLE OF THE FANTASTICALLY USEFUL 
2,08 =SSB TEXT EDITING SYSTEM, A NUMBER OF 
3,00 =EXAMPLES WILL BE SHOWN TO ALLOW EASY AND 
4,06 =QUICK LEARNING OF ITS FEATURES. 
5.08 =FOLLOWING ARE SOME NONSENSE LINES: 
6.88 =ABCDEFGHIJKL 
7,08 =AAAAAAAA 
8.08 =TESTING 1234 
9,00 =THIS EDITOW IS FUN TO USE! 

18.80 =BBBBBBBB 

11.08 = 

12.08 =THIS IS THE END OF THIS FILE, 

13.98 =AT LEAST FOR NOW. ; 

14,08 = 

15.08 =AT LEAST FOR NOW. 


Notice it was necessary to type a pound sign (#) in column one to 
leave the buffered input mode. At this time, the editor printed the 
last line and returned with its prompt (#). The editor is now ready 
to accept commands. 


Any time characters are being typed into the editor the following two 
characters have special meaning: 


1. "control" H -— Deletes the last character typed (backspace). 
2. “control" X - Deletes entire current line being typed. 


These are useful, when detected typing errors occur, for immediate 
correction. 


Each line of text in the edit file is given or has a line number which 
is used by the editor to uniquely identify the line. Each line number 
is of the form "m.nn" where "m" is an integer and "n" represents” any 
of the digits 6 through 9. To specify a line number, one has to 
specify only that portion of the line number to identify it uniquely. 
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For example, 73, 73., 73.8 and 73.08 may be used to refer to line 
73.90; 259.6 refers to line 259.66. The largest line number used with 
the editor is 9999.99. Let's denote a specification of a line of text 
by the symbol "<line>". We will be using this symbol throughout this 
document. 


An editor command tells the editor what action is to be performed and 
usually what line or block of lines are to be affected (if any). For 
each editing facility Supported by the editor, there is a directive 
which is used in commands to indicate the desired action. For 
example, the editor can delete lines of text from a file, insert lines 
of text into the file, print lines contained in the file, and so on, 
Corresponding to each capability there is a directive; hence, there 
is a Delete directive, an Insert directive, a Print directive, and so 
on. If we define the symbol <directive> to mean any editor directive, 
the basic form of an edit command is: 


<line><directive> 
For example, the command to display (print) line 12.98 is 


#12 P 
12.0@=THIS IS THE END OF THIS FILE, 
# 


where "12" is the <line> specification and "P" is the <directive> in 
this command. As can be seen in the example, this causes line number 
12 to be printed on the terminal. 


Now, let's learn how to use the INSERT directive. In normal usage of 
the word "insert" we say something like, "Insert this card after this 
other card." To use the insert directive, we specify the line after 
which we want to insert new lines followed by an 1: 


<line>l 


After typing the directive followed by a carriage return, the editor 
will select an appropriate line number and prompt for input by 
displaying the line number followed by an equal sign. After each line 
of text is entered and the carriage return is typed, the editor will 
prompt for the next line. To exit from the “Insert mode" one _ simply 
types a pound sign followed by an edit directive in response to a new 
line prompt. * 
Some examples of the use of Insert are 


#81 

~~ §8,10=THIS IS AN INSERTED LINE. 
8.29=SO IS THIS. 
8 .30=¥% 

#11T 
11.1@=ANOTHER INSERTED LINE. 
11.20=# 

#6P 
6. &©@=ABCDEFGHIJKL 
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It should be noted that the editor may renumber some lines following 
the inserted text. This occurs when enough lines are inserted such 
that the inserted line numbers overlap line numbers in the original 
text. 


Next, let's learn how to use the DELETE directive. With this 
directive we can delete one line or a block of lines with one 
directive. To delete only one line, we specify the <line> to be 
deleted followed by a D: 


<line>D 
When the carriage return is typed, the line is deleted, 


To delete more than 6éne line we need to indicate not only the first 
line to delete but also the last line to be deleted. Let's call the 
last line the "target" line and denote its specification as 
"<target">. Although the editor support fancier ways to _ specify 
the<target>, we'll just consider the two simplest: (1) <target> may 
be the number of lines to be deleted (counting both the first and last 
line of the block), or (2) <target> may be a pound sign followed 
immediately by the line, number of the last line of tthe block to be 
deleted. Some example” <targets> are: 3 (delete three lines), 26 
(delete 26 lines), and #26 (delete lines through line 26.00). 


The syntax to Delete a block of lines is 
<line>D <target> 


where <l  line> indicates the first line to delete and <target> 
indicates the scope of the delete, i 


To illustrate the use of the DELETE directive, let's assume we have a 
file containing 53 lines with integer line numbers (i.e., 1, 2, 3, 
eee, 593)e With the directives 


#1506 

#24D #31 

#52D 2 

BOTTOM OF FILE REACHED 
# 


we now have a file with lines 1 through 14, 16 through 23, and 32 
through 5l. The first directive deleted line 15, The second 
directive deleted lines 24 through 31. The third directive deleted 
two lines starting with .line 52, Since it deleted the last line of 
the file, the editor displayed the message "BOTTOM OF FILE REACHED". 


Before we discuss any more directives, we need to expand the 
definitions of <line> and <target>. 


As editing operations are performed, the editor keeps track of the 
"cucrent line" which usually is the line most recently affected by a 
successful edit directive. Upon entering the editor, the "current 
line" is the first line of the file. If, for example, we have just 
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inserted three lines between lines 12.88 and 13.09, the current line 
will be 12.30. One should note that after a line or a block of lines 
have been Deleted, the line immediately following the last one deleted 
is made the current line (if the last line of the file was deleted, 
the new last line of the file will be the current line). 


In our discussions above, we have implied that one has to explicitly 
indicate a <line> for each directive by specifying the line number of 
the line of interest. However, if <line> is not specified in a 
directive, the "current line" is used. For example, if one enters the 
directive 


#D2 
# 


the editor will delete two lines starting with the current line. In 
Our example, since we were at line 6.00, the "D2" operation deleted 
lines 6.88 and 7.08. As you will learn to appreciate, the "current 
line" default for line is extremely handy. 


After performing all of the above operations, our file now looks like 
this: 


1.9@8=THIS IS AN EXAMPLE OF THE FANTASTICALLY USEFUL 
2.08=SSB TEXT EDITING SYSTEM, A NUMBER OF 
3.99=EXAMPLES WILL BE SHOWN TO ALLOW EASY AND 
4,.099=QUICK LEARNING OF ITS FEATURES. 
5.90=FOLLOWING ARE SOME NONSENSE LINES: 
8.,00=TESTING 1234 
8.10=THIS IS AN INSERTED LINE, 
8.28=SO IS THIS. 
9.90=THIS EDITOR IS FUN TO USE! 
19.09=BBBBBBBB | 

11.900= 

11.1@0=ANOTHER INSERTED LINE. 

12.80=THIS IS THE END OF THIS FILE. 

13.80=AT LEAST FOR NOW. 


We have seen that <line> may be specified by a line number or by 
default to the current line. There are also several other ways to 
specify <line>, or in other words, to move the pointer to a 
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desired line prior to the execution of an edit directive. One may 
also specify <line> with a "+n" or "=n" (where n is an integer) 
meaning the next nth line in the file or the nth previous line in the 
file, respectively. Two other useful <line> designators are AAAA 
(AAAA on some terminals) and BBBB (1 on some terminals). The up arrow 
AAAA is used to designate the top or first line in the file. The down 
arrow BBBB is used to move to the last line or bottom of file. These 
various <line> specifiers are shown in the example below with the 
PRINT directive. 


#P 
1.8@=THIS IS AN EXAMPLE OF THE FANTASTICALLY USEFUL 
#43P 
4.90=QUICK LEARNING OF ITS FEATURES. 
#!1P 
13.98=AT LEAST FOR NOW. 
#-2P 


11.1@=ANOTHER INSERTED LINE. 


There may be times while editing a file when we know part of the 
contents of a line of interest but don't know its line number nor its 
displacement from the current line. In such a case we can use the 
"content-oriented" feature of the editor to find it. The syntax to 
specify <line> in this way is 


/<string>/ 


where "/" is a character to delimit (enclose) the <string> which is a 
sequence of characters known to be in the line. When <line> is 
specified as "/<string>/", the editor will search for the current line 
through the file to find the next line containing the specified 
<string>. Some exampJes will help to clarify this: (1) /PRINT/ 
denotes the next line containing theh character string "PRINT", and 
(2) /GO TO 35/ refers to the next line containing "GO TO 35". If the 
<string> is found in any subsequent line of the file, that line will 
be made the current line and the requested edit operation will be 
performed on it. If the <string> does not occur anywhere’ subsequent 
in the file, the editor will issue the message "NO SUCH LINE" and will 
not change the current line pointer. Note that the delimiter does not 
need to be a slash; it may be some other character such as a quote 
(') or a comma. For example, 'A/B‘ refers to the next line containing 
"A/B". : 


It is also possible to prefix the string designator with "-" (minus 
Sign) to indicate a previous line containing that string. A few 
examples with our TEST FILE will show the use of "/<string./" as a 
<line> designator. 


#-/QUICK/P 
4,.99=QUICK LEARNING OF ITS FEATURES. 
#;123; P 
8.00=TESTING 1234 
#+'END'P 
12.90=THIS IS THE END OF THIS FILE. 
# 
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To Summarize, we have seen that <line> may be specified a number of 
ways, namely: (1) by default to the current line, (2) by typing a line 
number, (3) by "+n" denoting the nth subsequent line, (4) by "=n" 
referring to the nth previous line, (5) by /<string>/ denoting the 
next line in the file containing the indicated string of characters, 
(6) "“-/<string>/" to denote the nearest previous line containing the 
specified character string, (7) AAAA (AAAA on some terminals) to 
denote the first line of the file, and (8) BBBB (BBBB on some 
terminals) to denote the last line of the file. 


Now let's turn our attention to expanding the definition of <target>, 
As you may recall, a <target> is used in some directives to indicate 
the number of lines to be affected by the edit operation. We have 
already seen that a <target> may be specified by (1) an integer "n" 
indicating the number of lines to be affected, as P3, meaning print 3 
lines, and (2) a line number preceded by a pound sign () indicating 
the line number of the last line to be affected, as P 6, meaning print 
all lines to and including line 6. The <target> is simply a 
designator telling how many lines the edit directive should operate 
on. In addition to the two mentioned forms of <target>, we also have, 
(3) if no <target> is specified in a command whose syntax includes 
one, a <target> of 1 is assumed, thereby affecting only one line. As 
with <line>, one may specify <target> by (4) "/<string>/" which 
indicates the next line in the file containing the specified character 
string, (5) AAAA to denote the top line in the file, and (6) BBBB to 
denote the bottom line in the file. A minus sign may be used to 
indicate that processing is to proceed backward through the file in 
the following two cases: (7) "=n" and (8) "-/<string>/". 


With an understanding of <line> and <target> we can now discuss some 
more directives. The Print directive is used to display a line or a 
group of lines. Its syntax is 


<line>P <target> 


where "“<line>" and "“<target>" may be specified in any of the ways 
discussed above. To print just one line one needs to _ specify only 
<line> followed by a carriage return; therefore, the following two 
directives perform the same thing: 


<line>P 
and 
<line> 


Going back to our test file, we can illustrate the various forms of 
<target> as used with the Print directive. . 


#2P 
2.90=SSB TEXT EDITING SYSTEM. A NUMBER OF 
#-1] 


1.0@=THIS IS AN EXAMPLE OF THE FANTASTICALLY USEFUL 
#P_/EASY/ 
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1.0@0=THIS IS AN EXAMPLE OF THE FANTASTICALLY USEFUL 
2.98=SSB TEXT EDITING SYSTEM. A NUMBER OF 
3.9@=EXAMPLES WILL BE SHOWN TO ALLOW EASY AND 
#! P -3 
13.8G6=AT LEAST FOR NOW. 
12.08=THIS IS THE END OF THIS FILE. 
11.18=ANOTHER INSERTED LINE. 
#-/BBB/ P -/123/ 
10.90=BBBBBBBBB 
9.9@=THIS EDITOR IS FUN TO USE! 
8.20=SO IS THIS. 
8.1@=THIS IS AN INSERTED LINE. 
8.00=TESTING 1234 
#12P! 
12.88=THIS IS THE END OF THIS FILE. 
13.88=AT LEAST FOR NOW. 


The first directive displayed line 2.9@ and made that line the current 
line, The second directive requested that the line immediately 
preceding the current line be displayed. The third directive 
displayed the block of lines from the current line down through the 
line containing the character string “EASY". The fourth directive 
printed 3 lines starting at the bottom of the file and ending at line 
11.18, which became the current line. The fifth directive requested 
the previous line containing the character string "BBB" be found, ~ and 
then starting with that line, display all lines going backwards 
through the file until a line containing the character string "123" 
has been displayed. This shows the extreme usefulness and power of 
the content-oriented characteristic of the editor, The last directive 
requested that all lines from line 12.98 to the end or bottom of file 
be displayed. 


The next directive to discuss is Next which is used primarily to move 
the current pointer. Although it may be used otherwise, usually it is 
used only with the default <line>. Its syntax is 

N <target> 


This directive finds the line indicated by target, displays it and 
makes it the current line. A few examples will illustrate its use. 


#P 

~ 1,@@=THIS IS AN EXAMPLE OF THE FANTASTICALLY USEFUL 
#N ; 

~ 2,09=SSB TEXT EDITING SYSTEM. A NUMBER OF 

#N 6 : 


8.28=SO IS THIS. 
#N -2 

8.09=TESTING 1234 
# 


The following directive performs single-line replacements or inserts. 
Its syntax is 


<line>=<text> 
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where "<line>" specifies the number of the line to be replaced or 
inserted and may, of course, default to the current line. "<text>" 
is the text to comprise the line. To illustrate this directive, let's 
continue our example series, 


#=REPLACE CURRENT LINE HERE 
#5.25=THIS LINE CREATED WITH “EQUALS". 
# 


The first directive changed the contents of line 8.98, the current 
line. The second example inserted a line with the line number 5,25. 


The next directive to be discussed is the CHANGE directive. It is 
used to change occurrences of one character string into another. Its 
syntax is 


<line>C /<string> /<string> / <target> <occurrence> 


where "/" is a delimiter character to separate the two character 
strings; "<string> " is the character string to be replaced; 
"<string> " is the string of characters to replace them; "<target>" 
specifies the range of the changes; and "“<occurrence>" specifies 
which occurrence(s) is 1 or is not specified, then only the first 
occurrence of <string> in any line of the block will be changed -- 
the second or subsequent occurrence of the string in such a line will 
not be affected. If 2 is specified for <occurrence>, then only the 
second occurrence of <string> in any line of the block will be 
changed, To change all occurrences of the indicated string in the 
block, use an asterisk (*) for <occurrence>, Let's illustrate the 
Change directive by continuing our example. 


#4C/QUICK/FAST/ 
4,8@0=FAST LEARNING OF ITS FEATURES, 
#8,1 C /THIS IS // 
8.@1@=AN INSERTED LINE, 
#-5C 3A3$;  ;SOME; * 
3.98=EXSMPLES WILL BE SHOWN TO SLLOW ESSY SND 
4,.Q0@=FSST LESRNING OF ITS FESTURES,. 
5.@G=FOLLOWING SRE SOME NONSENSE LINES: 
#12C /E/?/ -2 3 ss 
12.@0=THIS IS THE END OF THIS FIL?, 
11.16=ANOTHER INSERT?D LINE. 


The first example replaced the string "QUICK" with the string "FAST" 
in line 4.00. The second example deleted the string "THIS IS" and a 
blank from line 8.18. The third example starts at the fifth previous 
line (line 3.88) and changes every occurrence of "A" to "S$" down 
through all lines until the line containing the character string 
"SOME" (line 5.88) is reached. The last example changes the third 
occurrence of "E" to "?" in line 12.08 and then in line 11.19. 


The last directive to be discussed is used to exit from the editor. 
This can be done several different ways: STOP, S, OR LOG. This will 
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return you to your system monitor. 


Now let's go back to our test file and illustrate some of the features 
and directives we have discussed, 


#P! 
~~ 1,0@=THIS IS AN EXAMPLE OF THE FANTASTICALLY USEFUL 
2.00=SSB TEXT EDITING SYSTEM, A NUMBER OF 
3. 9@0=EXSMPLES WILL BE SHOWN TO SLLOW ESSY SND 
4.90=FSST LESRNING OF ITS FESTURES, 
5.80=FOLLOWING SRE SOME NONSENSE LINES: 
5.25=THIS LINE CREATED WITH A"EQUALS", 
8.00=REPLACE CURRENT LINE HERE 
8.18=AN INSERTED LINE, 
8.20=SO IS THIS, 
9,.98=THIS EDITOR IS FUN TO USE! 
18.88=BBBBBBBBBB 
11.90= 
11.1@=ANOTHER INSERT?D LINE. 
12.8@0=THIS IS THE END OF THIS FIL?, 
13.90=AT LEAST FOR NOW. 
# 2C/EDITING/EDITOR/ 
2.00=SSB 6880 TEXT EDITOR SYSTEM. A NUMBER OF 
+/BBB/ 
18.90= BBBBBBBBBB 
#-;THIS IS C 'B'xx! 
l. VEER IS AN TREAMPLE OF THE FANTASTICALLY USEFUL 
2.80=SSB 68008 TXXXT EDITING SYSTEM. A NUMBER OF 
3. OO=XXX$MPLES WILL BE SHOWN TO 7@LOW ESSY SND 
4,0@=FSST LXXSRNING OF ITS FESTURES, 
5.8@=FOLLOWING $RXX SOME NONSENSE LINES: 
5.25=THIS LINXX CREATED WITH "EQUALS". 
8.90=RXXPLACE CURRENT LINE HERE 
8.10=AN INSXXRTED LINE. 
9. 9@=THIS XXDITOR IS FUNE TO USE! 
11.18=ANOTHXXR INSERT?D LINE. 
12.90=THIS IS THXX END OF THIS FIL?, 
: 13.80=AT LXXAST FOR NOW. 
N-4 
~ 19.68=BBBBBBBBB 
#-11 
9.1@=TEST-TEST-TEST 
9. 20=1234567898 
9.30=#D! 
BOTTOM OF FILE REACHED 
#D! 
BOTTOM OF FILE REACHED 
#1P! 
#LOG 


The previous tutorial has been only a brief introduction to the SSB 
Text Editing System. It is important to read and study the entire 
manual in order to fully understand all the power and features of this 
editor. 
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